<!DOCTYPE html>
<html lang="en"  xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="UTF-8">
    <title>仓库管理系统</title>
    <meta name="renderer" content="webkit">
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
    <meta http-equiv="Access-Control-Allow-Origin" content="*">
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
    <meta name="apple-mobile-web-app-status-bar-style" content="black">
    <meta name="apple-mobile-web-app-capable" content="yes">
    <meta name="format-detection" content="telephone=no">
    <link rel="stylesheet" href="/resources/layui/css/layui.css" media="all" />
    <link rel="stylesheet" href="/resources/css/public.css" media="all" />
</head>
<body class="childrenBody">
<!--搜索条件开始-->
<div>
    <fieldset class="layui-elem-field layui-field-title" style="margin-top: 20px;">
        <legend>查询条件</legend>
    </fieldset>
    <form class="layui-form layui-form-pane" lay-filter="searchFrm" id="searchFrm" name="searchFrm" method="post">
        <div class="layui-form-item">
            <div class="layui-inline">
                <label class="layui-form-label">供应商</label>
                <div class="layui-input-inline">
                    <select name="providerid" id="search_providerid">
                        <option value="0">请选择供应商</option>
                    </select>
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">商品名称</label>
                <div class="layui-input-inline">
                    <input type="text" name="goodsname"  autocomplete="off" class="layui-input">
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">生产批号</label>
                <div class="layui-input-inline">
                    <input type="text" name="productcode"  autocomplete="off" class="layui-input">
                </div>
            </div>
        </div>
        <div class="layui-form-item">
            <div class="layui-inline">
                <label class="layui-form-label">批准文号</label>
                <div class="layui-input-inline">
                    <input type="text" name="promitcode"  autocomplete="off" class="layui-input">
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">商品描述</label>
                <div class="layui-input-inline">
                    <input type="text" name="description"  autocomplete="off" class="layui-input">
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">商品规格</label>
                <div class="layui-input-inline">
                    <input type="text" name="size"  autocomplete="off" class="layui-input">
                </div>
            </div>
        </div>
        <div class="layui-form-item" style="text-align: center">
            <div class="layui-inline">
                <button type="button" class="layui-btn layui-btn-normal  layui-icon layui-icon-search" lay-filter="doSearch" lay-submit="">查询</button>
                <button type="reset" class="layui-btn layui-icon layui-icon-refresh">重置</button>
            </div>
        </div>
    </form>
</div>
<!--搜索条件结束-->

<!--数据表格开始-->
<div>
    <table class="layui-hide" id="GoodsTable" lay-filter="GoodsTable"></table>
    <div id="GoodsToolBar" style="display: none;">
        <button type="button" lay-event="addGoods" class="layui-btn layui-btn-sm "><span class="layui-icon layui-icon-add-circle"></span>添加商品</button>
        <button type="button" lay-event="batchDelete" class="layui-btn layui-btn-sm layui-btn-danger"><span class="layui-icon layui-icon-delete"></span>批量删除</button>
    </div>
    <div id="GoodsRowBar" style="display: none">
        <button type="button" lay-event="delete" class="layui-btn layui-btn-sm layui-btn-danger"><span class="layui-icon layui-icon-delete"></span>删除</button>
        <button type="button" lay-event="update" class="layui-btn layui-btn-sm "><span class="layui-icon layui-icon-set-sm"></span>更新</button>
        <button type="button" lay-event="view" class="layui-btn layui-btn-sm layui-btn-warm"><span class="layui-icon layui-icon-set-sm"></span>查看大图</button>
    </div>
</div>
<!--数据表格结束-->

<!--添加和修改的弹出层开始-->
<div style="display: none;padding: 20px" id="saveOrUpdateDiv" >
    <form action="" method="post" class="layui-form layui-form-pane" id="dataFrm" lay-filter="dataFrm">
        <div class="layui-col-md12 layui-col-xs12">
            <div class="layui-row layui-col-space10">
                <div class="layui-col-md9 layui-col-xs7">
                    <div class="layui-form-item magt3">
                        <label class="layui-form-label">供应商</label>
                        <div class="layui-input-block">
                            <select name="providerid" id="providerid">
                                <option value="0">请选择供应商</option>
                            </select>
                        </div>
                    </div>
                    <div class="layui-form-item">
                        <label class="layui-form-label">商品名称</label>
                        <div class="layui-input-block">
                            <input type="hidden" name="id">
                            <input type="text" class="layui-input" name="goodsname" lay-verify="required" placeholder="请输入商品名称">
                        </div>
                    </div>
                    <div class="layui-form-item">
                        <label class="layui-form-label">商品描述</label>
                        <div class="layui-input-block">
                            <input type="text" class="layui-input" name="description" lay-verify="required" placeholder="请输入商品描述">
                        </div>
                    </div>
                </div>
                <div class="layui-col-md3 layui-col-xs5">
                    <div class="layui-upload-list thumbBox mag0 magt3">
                        <input type="hidden" name="goodsimg" id="goodsimg" value="images/defaultgoodsimg.png"> <!--保存文件上传的地址-->
                        <img class="layui-upload-img thumbImg" src="/file/showImageByPath?path=images/defaultgoodsimg.jpg"> <!--显示默认图片-->
                    </div>
                </div>
            </div>
            <div class="layui-form-item magb0">
                <div class="layui-inline">
                    <label class="layui-form-label">产地</label>
                    <div class="layui-input-inline">
                        <input type="text" class="layui-input" name="produceplace" lay-verify="" placeholder="请输入商品产地">
                    </div>
                </div>
                <div class="layui-inline">
                    <label class="layui-form-label">包装</label>
                    <div class="layui-input-inline">
                        <input type="text" class="layui-input" name="goodspackage" lay-verify="" placeholder="请输入商品包装">
                    </div>
                </div>
                <div class="layui-inline">
                    <label class="layui-form-label">规格</label>
                    <div class="layui-input-inline">
                        <input type="text" class="layui-input" name="size" lay-verify="" placeholder="请输入商品规格">
                    </div>
                </div>
                <div class="layui-inline">
                    <label class="layui-form-label">生产批号</label>
                    <div class="layui-input-inline">
                        <input type="text" class="layui-input" name="productcode" lay-verify="" placeholder="请输入商品生产批号">
                    </div>
                </div>
                <div class="layui-inline">
                    <label class="layui-form-label">批准文号</label>
                    <div class="layui-input-inline">
                        <input type="text" class="layui-input" name="promitcode" lay-verify="" placeholder="请输入商品批准文号">
                    </div>
                </div>
                <div class="layui-inline">
                    <label class="layui-form-label">销售价格</label>
                    <div class="layui-input-inline">
                        <input type="text" class="layui-input" name="price" lay-verify="" placeholder="请输入商品销售价格">
                    </div>
                </div>
                <div class="layui-inline">
                    <label class="layui-form-label">库存量</label>
                    <div class="layui-input-inline">
                        <input type="text" class="layui-input" name="number" lay-verify="" placeholder="请输入商品库存量">
                    </div>
                </div>
                <div class="layui-inline">
                    <label class="layui-form-label">预警值</label>
                    <div class="layui-input-inline">
                        <input type="text" class="layui-input" name="dangernum" lay-verify="" placeholder="请输入商品预警值">
                    </div>
                </div>
                <div class="layui-inline">
                    <label class="layui-form-label">是否可用</label>
                    <div class="layui-input-inline">
                        <input type="radio" name="available" value="1" title="可用" checked="">
                        <input type="radio" name="available" value="0" title="不可用" >
                    </div>
                </div>
            </div>

            <div class="layui-form-item">
                <div class="layui-input-block" style="text-align: center;">
                    <button type="button" class="layui-btn" lay-submit="" lay-filter="doSubmit" id="doSubmit" ><span class="layui-icon layui-icon-add-1"></span>提交</button>
                    <button type="reset" class="layui-btn layui-btn-warm"><span class="layui-icon layui-icon-refresh-1"></span>重置</button>
                </div>
            </div>
        </div>
    </form>
</div>
<!--添加和修改的弹出层结束-->

<!-- 图片大查看 -->
<div id="viewGoodsImageDiv" style="display:none;text-align:center">
    <img alt="车辆图片" width="550" height="350" id="view_image">
</div>

<script type="text/javascript" src="/resources/layui/layui.js"></script>
<script>
    layui.use(['jquery','layer','form','table','upload'],function () {
        var form=layui.form;
        var $=layui.jquery;
        var layer=layui.layer;
        var table=layui.table;
        var upload = layui.upload;


        var tableIndex = table.render({
            elem: '#GoodsTable'
            ,url:'/goods/loadAllGoods'
            ,toolbar: '#GoodsToolBar' //开启头部工具栏，并为其绑定左侧模板
            ,title: '商品数据表'
            ,height: 'full-220'
            ,page: true
            ,cols: [ [
                {type:'checkbox',align:'center'}
                ,{field:'id', title:'ID',align:'center' ,width:'80'}
                ,{field:'goodsname', title:'商品名称',align:'center',width:'150'}
                ,{field:'providername', title:'供应商',align:'center',width:'120'}
                ,{field:'produceplace', title:'产地',align:'center',width:'120'}
                ,{field:'size', title:'商品规格',align:'center',width:'120'}
                ,{field:'goodspackage', title:'商品包装',align:'center',width:'120'}
                ,{field:'productcode', title:'生产批号',align:'center',width:'100'}
                ,{field:'promitcode', title:'批准文号',align:'center',width:'100'}
                ,{field:'description', title:'商品描述',align:'center',width:'120'}
                ,{field:'price', title:'商品价格',align:'center',width:'100'}
                ,{field:'number', title:'库存量',align:'center',width:'100'}
                ,{field:'dangernum', title:'预警库存',align:'center',width:'100'}
                ,{field:'goodsimg', title:'商品图片',align:'center',width:'100', templet:function(d){
                    return '<img width=40 height=40 src=/file/showImageByPath?path='+d.goodsimg+ ' />';
                }}
                ,{field:'available', title:'是否可用',align:'center',width:'100',templet:function(d){
                    return d.available==1?'<font color=blue>可用</font>':'<font color=red>不可用</font>';
                }}
                ,{fixed: 'right', title:'操作', toolbar: '#GoodsRowBar',align:'center',width:'350'}
            ] ]
            ,done:function(data,curr,count){
                //不是第一页如果返回的数据为0那么就返回上一页
                if(data.data.length==0&&curr!=1){
                    tableIndex.reload({
                        page:{
                            curr:curr-1
                        }
                    });
                }
            }
        });


        //加载查询条件供应商的下拉列表
        $.get("/provider/loadAllProviderForSelect",function(res){
            var data=res.data;
            var dom=$("#search_providerid");
            var html='<option value="0">请选择供应商</option>'
            $.each(data,function(index,item){
                html+='<option value="'+item.id+'">'+item.providername+'</option>'
            });
            dom.html(html);
            form.render("select");
        })

        //模糊查询
        form.on('submit(doSearch)',function(data){
            var params = $("#searchFrm").serialize();
            tableIndex.reload({
                url: "/goods/loadAllGoods?" + params,
                page:{
                    curr:1
                }
            })
            return false;
        });

        //头工具栏事件
        table.on('toolbar(GoodsTable)', function(obj){
            switch(obj.event){
                case 'batchDelete':
                    BatchDelete();
                    break;
                case 'addGoods':
                    openAddGoods();
                    break;
            };
        });


        //监听行工具条的事件
        table.on("tool(GoodsTable)",function(obj){
            var data = obj.data; //获得当前行数据
            switch(obj.event){
                case 'delete':
                    DeleteGoods(data);
                    break;
                case 'update':
                    UpdateGoods(data);
                    break;
                case 'view':
                    openViewImage(data);
                    break;

            };
        });

        var url;
        var mainIndex;

        //添加添加页面
        function openAddGoods() {
            mainIndex = layer.open({
                type:1,
                title:'添加供商品',
                content:$("#saveOrUpdateDiv"),
                area:['800px','550px'],
                success:function(index){

                    //清空表单数据
                    $("#dataFrm")[0].reset();
                    //显示默认图片
                    $('.thumbImg').attr('src','/file/showImageByPath?path=images/defaultgoodsimg.jpg');
                    //设置图片默认地址
                    $("#goodsimg").val('images/defaultgoodsimg.jpg');

                    //加载查询条件供应商的下拉列表
                    $.get("/provider/loadAllProviderForSelect",function(res){
                        var data=res.data;
                        var dom=$("#providerid");
                        var html='<option value="0">请选择供应商</option>'
                        $.each(data,function(index,item){
                            html+='<option value="'+item.id+'">'+item.providername+'</option>'
                        });
                        dom.html(html);
                        form.render("select");
                    })
                    url="/goods/addGoods";
                }
            });
        }

        //更新页面
        function UpdateGoods(data){
            mainIndex = layer.open({
                type:1,
                title:'修改商品',
                content:$("#saveOrUpdateDiv"),
                area:['800px','550px'],
                success:function(index){

                    form.val("dataFrm",data);
                    url="/goods/updateGoods";

                    //加载查询条件供应商的下拉列表
                    $.get("/provider/loadAllProviderForSelect",function(res){
                        var resdata=res.data;
                        var dom=$("#providerid");
                        var html='<option value="0">请选择供应商</option>'
                        $.each(resdata,function(index,item){
                            if (data.providerid===item.id){
                                html+='<option value="'+item.id+'" selected>'+item.providername+'</option>'
                            }else{
                                html+='<option value="'+item.id+'">'+item.providername+'</option>'
                            }
                        });
                        dom.html(html);
                        form.render("select");
                    })

                    //弹出层显示图片
                    $('.thumbImg').attr('src','/file/showImageByPath?path='+data.goodsimg);
                }
            });
        }

        //保存
        form.on("submit(doSubmit)",function(obj){
            //序列化表单数据
            var params=$("#dataFrm").serialize();
            $.post(url,params,function(obj){
                layer.msg(obj.msg);
                //关闭弹出层
                layer.close(mainIndex);
                //刷新数据 表格
                if (obj.code ==200){
                    tableIndex.reload();
                }
            })
            return false;
        });

        //文件上传
        upload.render({
            elem: '.thumbBox',
            url: '/file/uploadFile', //文件上传路径
            acceptMime:'image/*',
            field:'mf',
            size: 200,
            method : "post",  //此处是为了演示之用，实际使用中请将此删除，默认用post方式提交
            done: function(res, index, upload){
                //请求上面url后 返回值res
                var path=res.path;
                $('.thumbImg').attr('src','/file/showImageByPath?path='+path);
                $('.thumbBox').css("background","#fff");

                //给隐藏域赋值 相对路径
                $("#goodsimg").val(path);
            }
        });

        //批量删除
        function BatchDelete() {
            //得到选中行
            var checkStatus = table.checkStatus('GoodsTable');
            var dataLength = checkStatus.data.length;
           // console.log(dataLength);
            if (dataLength>0){
                layer.confirm('你确定要删除这些数据吗?', {icon: 3, title:'提示'}, function(index){
                    var data = checkStatus.data; //获取选中行的数据
                    var ids = '';
                    //拼接商品ID
                    $.each(data,function (index,item) {
                        if (index == 0){
                            ids += 'ids='+ item.id;
                        }else{
                            ids += '&ids='+ item.id;
                        }
                    })
                    //拼接图片path
                    $.each(data,function (index,item) {
                        ids += '&paths='+ item.goodsimg;
                    })

                    //layer.msg(ids);
                    $.post("/goods/batchDeleteGoods",ids,function (res) {
                        if(res.code==200){
                            tableIndex.reload();
                        }
                        layer.msg(res.msg);
                    })
                    layer.close(index);
                })
            }else{
                layer.msg("请选中行");
            }
        }

        //删除
        function  DeleteGoods(data) {
            layer.confirm('你确定要删除这条数据吗?', {icon: 3, title:'提示'}, function(index){
                $.post("/goods/deleteGoods",{id:data.id,goodsimg:data.goodsimg},function(res){
                    if(res.code==200){
                        tableIndex.reload();
                    }
                    layer.msg(res.msg);
                })
                layer.close(index);
            });
        }

        //查看大图
        function openViewImage(data){
            mainIndex=layer.open({
                type:1,
                title:"商品【"+data.goodsname+'】的图片',
                content:$("#viewGoodsImageDiv"),
                area:['600px','400px'],
                success:function(index){
                    $("#view_image").attr("src",'/file/showImageByPath?path='+data.goodsimg);
                }
            });
        }
    })
</script>
</body>
</html>